| Signal                     | From                  | То                                                   | Task                                                                                          |
|----------------------------|-----------------------|------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| c1k                        |                       | Bus                                                  | This clock times all bus transfers. All signal timings are related to the rising edge of HCLK |
| ${\tt sb\_lock\_m1}$       | Master 1              | Arbiter                                              | Lock request                                                                                  |
| req1                       | Master 1              | Arbiter                                              | Request for bus                                                                               |
| req2                       | Master 2              | Arbiter                                              | Request for bus                                                                               |
| Sb_lock_m2                 | Master 2              | Arbiter                                              | Lock request                                                                                  |
| resp0                      | Slave 0               | Mux3-1_Resp                                          | Response from slave 0                                                                         |
| resp1                      | Slave 1               | Mux3-1_Resp                                          | Response from slave 1                                                                         |
| resp2                      | Slave 2               | Mux3-1_Resp                                          | Response from slave 2                                                                         |
| Resp<br>HADDR_M1<br>[14:0] | Mux3-1_Resp  Master 1 | ADD_mux (This is a 2 to 1 mux for address & control) | Address from master 1                                                                         |
| HADDR_M2<br>[14:0]         | Master 2              | ADD_mux                                              | Address from master 2                                                                         |
| HADDR<br>[14:0]            | ADD_mux               | Decoder                                              | For slave selection first 2 bits specify the slave 00 - slave 0 01 - slave 1 10 - slave 2     |
| RDATA_S0 [31:0]            | Slave 0               | Read mux (This is a 3-1 mux for read data)           | Getting read<br>data from slave<br>0                                                          |
| RDATA_S1<br>[31:0]         | Slave 1               | Read mux                                             | Getting read data from slave                                                                  |

| RDATA_S2<br>[31:0]   | Slave 2        | Read mux                 | Getting read<br>data from slave<br>2                                       |
|----------------------|----------------|--------------------------|----------------------------------------------------------------------------|
| WDATA_M1<br>[31:0]   | Master 1       | Write data mux           | Getting write<br>data from master<br>1                                     |
| WDATA_M2<br>[31:0]   | Master 2       | Write data mux           | Getting write<br>data from master<br>1                                     |
| Sb_split_ar<br>[1:0] | Slave          | Arbiter                  |                                                                            |
| sel_slave<br>[1:0]   | Decoder        | Mux3-1_Resp<br>Read mux  | Sending slave selection data to mux                                        |
| WDATA<br>[31:0]      | Write data mux | Slave                    | Sending write data to slave                                                |
| gnt1                 | Arbiter        | Master 1                 | Grant the master  1 ( master 1 - granted  master 2 - not granted)          |
| gnt2                 | Arbiter        | Master 2                 | Grant the master 2. ( master 1 - not granted  master 2 - granted)          |
| Sb_masters [1:0]     | Arbiter        | ADD_mux<br>(Address mux) | Specify the selected master.  00 - no master  01 - master 1  10 - master 2 |
| Sb_mastlock          | Arbiter        | Slave                    | 1 - lock<br>0 - no lock                                                    |
| RDATA [31:0]         | Read mux       | Master                   | Data bus carries read data from mux to master                              |
| se1_0                | Decoder        | Slave 0                  | 1 - selected<br>0 - not selected                                           |
| se1_1                | Decoder        | Slave 1                  | 1 - selected<br>0 - not selected                                           |
| se1_2                | Decoder        | Slave 2                  | 1 - selected<br>0 - not selected                                           |
| sel_slave<br>[1:0]   | Decoder        | Mux3-1_Resp<br>Read mux  | Sending slave<br>selected data to<br>muxes<br>00 - slave 0                 |

|              |                |       | 01 - slave 1<br>10 - slave 2 |
|--------------|----------------|-------|------------------------------|
| WDATA [31:0] | Write data mux | Slave | Sending write data to slave  |



Bus architecture diagram

Top Module Architecture Diagram

